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Abstract (Basic) : EP 540095 A 

The microcircuit is used in a multi-application smart card having a 
read-only memory (12), a programmable memory (13) and a circuit 
controlling addressing of the programmable memory. 

The programmable memory is divided into two zones: an index zone 
and an application zone. The index zone holds for each application a 
reference code and the addresses of the start and finish of the space 
allocated to each application. The microcircuit can also inhibit all . 
commands to the programmable memory when it is associated with an 
address outside the address range of the application, unless it is from 
a priority operation held in ROM. 

ADVANTAGE - Prevents illicit writing to blank smart cards. 

Dwg. 1/3 

Abstract (Equivalent) : EP 540095 B 

The microcircuit is used in a multi-application smart card having a 
read-only memory (12), a programmable memory (13) and a circuit 
controlling addressing of the programmable memory. 

The programmable memory is divided into two zones: an index zone 
and an application zone. The index zone holds for each application a 
reference code and the addresses of the start and finish of the space 
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allocated to each application. The microcircuit can also inhibit all 
commands to the programmable memory when it is associated with an 
address outside the address range of the application, unless it is from 
a priority operation held in ROM. 

ADVANTAGE - Prevents illicit writing to blank smart cards. 

Dwg.1/3 

Abstract' (Equivalent): US 5452431 A 

A microcircuit for a chip card, comprising: 

(a) a processor for accessing a memory address space; 

(b) a read-only memory in the memory address space and which 
contains functional routines that are exclusively accessible to the 
processor; 

(c) a programmable memory in the memory address space comprising a 
repertory region and an application region which are distinct from one 
another, the application region being allocable into separate and 
distinct application sub-regions, each sub-region being allocable for 
accommodating storage of one of a plurality of independent application, 
programs, each of said application sub-regions when loaded with an 
application program comprising an address space defined by contiguous 
addresses between unique upper and lower limit address values, the 
repertory region accommodating storage containing, for each application 
program stored in a respective application sub-region, a respective 
reference code and respective upper and lower limit address values of 
contiguous addresses of an application sub-region exclusively allocated 
to an application program; 

(d) lockable means for storing upper and lower limit address 
values; 

(e) the functional routines in said read-only memory comprising, 
under the control of the processor, a first routine for loading an 
application program into an application sub-region including allocating 
address space needed by the application program and storing upper and 
lower limit address values of said allocated address space in the 
repertory region, and a second routine for obtaining from the repertory 
region and loading in the lockable means upper and lower limit address 
values of a particular application program in response to a call from 
the processor to run the particular application program; 

(f) control means for controlling access to the programmable memory 
including: 

(i) means for making a comparison between an address requested by a 
running application program and upper and lower limit address values 
stored in the lockable means by said second routine from the repertory 
region and corresponding to the running application program; 

(ii) means in response to the requested address lying inside the 
upper and lower limit address values in the lockable means for granting 
memory access to the requested address and in response to the requested 
address lying outside the upper and lower limit address values for 
denying memory access; 

(iii) in response to a command to run a designated application 
program, a priority authorization channel for temporarily unlocking 
said lockable means. and for storing therein the upper and lower limit 
address values of the designated application program when the second 
routine is executed and for restoring a locked condition to the 
lockable means while the designated application program is running; 

(g) the processor comprising an instruction counter, and the 
priority authorization channel comprising a flip-flop connected to 
receive a reset command from the processor when the processor is • 
initialized, and to receive a. set command in response to an address 
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value contained in the instruction counter when said address value 
designates an address in the address space of the programmable memory, 
said flip-flop being operative to supply a locking/unlocking signal for 
controlling the locking of the lockable means and for controlling the 
priority authorization channel. 
Dwg.1/3 
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© Microcircuit pour carte a puce multi -applica- 
tions comportant notamment une me*moire ROM 
(12), une memoire programmable (13) et un circuit 
de controle d'adressage (14) de cette memoire 
programmable. 

Selon Pinvention, la memoire programmable (13) 
est partagee en au moins une zone de repertoire 
(ZR) et une zone des applications (ZA), la zone de 
repertoire (ZR) comportant par application charged, 
au moins un code de reference d'une application i 
prSsente dans la zone ZAj ainsi que les adresses 
ZAn et ZAj h respectivement de debut et de fin de la 
zone ZA| alloue*e a cette application. 

Le microcircuit comporte e*galement des moyens 
(25 a 50) pour inhiber toute commando (R, W ou E) 
de la memoire programmable (13) lorsqu'elle est 
relative a une adresse exteVieure a Tintervalle ZA« - 
ZA ih de ('application en cours de traitement et sauf 
s'il s'agit d'une operation prioritaire sp^cifiquement 
prSvue par un programme fixe" dans la me*moire 
ROM (12). 

Application : carte a microcircuits. 
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La pr^sente invention concerne un microcircuit 
pour carte a puce comprenant entre-autres : des 
moyens d'acces entree - sortie, au moins une 
m£moire qui est programmable et accessible par 
un espace d'adressage a adresses cons£cutives, 
un circuit de contr6le d'adressage de cette m§- 
moire programmable determinant soit une inhibi- 
tion, soit une validation des commandos d'£criture 
et/ou de lecture par la comparaison de I'adresse 
demand^e avec deux vaieurs Hmites de d£but et 
de fin d'une zone particuliere d'adresses, limites 
qui sont memoris^es au sein du circuit de controle 
d'adressage lequel circuit comporte egalement une 
voie d'autorisation prioritaire permettant de s'af- 
franchir temporairement de ladite inhibition dans 
des circonstances pr^d^termin^es et particulieres. 

Un tel microcircuit est notamment connu du 
document FR 2 304 989. 

L'application dans le domaine bancaire des 
cartes portatives au sein desquelles est incorpor^ 
un circuit int^grd yiectronique (encore appele* 
"puce") est bien connue ainsi que la grande se - 
curity de fonctionnement qui en r^sulte. II est en 
effet pratiquement impossible d'acceder a certai - 
nes donnees inscrites dans des zones protegees 
du microcircuit sans le detruire. Par ailleurs, lors de 
Tutilisation, un protocole d' identification faisant in - 
terveriir un code personnel et secret, inscrit dans 
une zone protegee du microcircuit, permet d'in- 
terdire toute tentative d'usage de la carte si les 
conditions ^identification ne sont pas satisfaites. 

Dans le cas d'une carte bancaire, le fabricant 
de carte cr6e dans un premier temps des cartes 
dont le microcircuit est vierge de toute information 
personnalise*e, puis dans un deuxieme temps, il y 
inscrit, par programmation des donnees secretes, 
personnalisant chaque carte. Les cartes sont en - 
suite prot£g£es par des verrous technologiques 
irreversibles. 

Les codes personnels d'identification sont alors 
envoy^s a chaque utilisateur (clients de la ban- 
* que), et, par une autre route, les cartes elles- 
mimes sont exp£die*es a la banque, oCi les clients 
sont pri^s de venir les retirer. Ce systeme se 
r£vele d'une grande security contre les tentatives 
d'usurpation. 

Bien entendu, une carte a puce est susceptible 
de servir a bien d'autres applications, en dehors du 
domaine bancaire, ou I'aspect pratique de porta- 
bility de la carte et de sa s£curite* d'utilisation 
offrent des perspectives inteVessantes. 

On peut penser a d§velopper un microcircuit 
sp^cifique de chaque cas d'application particulier 
envisage mais il est plus yconomique et plus sim - 
pie de preVoir des microcircuits d'un type suffi- 
samment universel pour que I'une ou I'autre des 
applications envisaged y soit ensuite programmed. 



Dans cette perspective, des problemes appa- 
raissent dyja du point de vue de la sy curity si on 
envisage de confier a une entity autre que le 
fabricant de microcircuit, le soin d'inscrire les 

5 donnees secretes d'identification et les donnees 
fonctionnelles de sa propre application. 

En effet une personne mat intentionn^e ayant 
nSussi a se procurer des cartes vierges et ayant 
par ailleurs pris connaissance des techniques 

10 description d'une certaine application, serait sus - 
ceptible de reenter illicitement des cartes falsifiees 
en utilisant une technique description de donnees 
qui imite roriginale. 

Or, I'entity ^mettrice de l'application, qui est 

/5 ytrangere au fabricant de microcircuit. peut d£sirer 
charger elle - m§me les donn§es de son applica - 
tion, entre-autres pour ne pas livrer ses secrets 
au fabricant de microcircuits. 

Ces difficult^s relatives a la s£curit£ sont en - 

20 core aggravees dans le cas ou on envisage de 
cre*er des cartes dites "multi- application" d'un 
type universel, vierges a I'origine, et qui sont aptes 
a etre chargdes successivement et dans un ordre 
de succession quelconque, de donnees et pro- 

25 grammes duplications diffe*rents les uns des au - 
tres, par des entites Smettrices qui sont etrangeres 
les unes aux autres. Le but recherche* sera alors 
d'effectuer une allocation dynamique de la m§- 
moire programmable dans des conditions de se - 

30 curite* satisfaisantes. 

Le fabricant de microcircuits devrait pouvoir 
assurer une possibility de protection de plusieurs 
zones de memoire dont il ne conhaD pas encore 
les limites individuelles, de maniere que chaque 

35 entity ymettrice puisse proteger la zone ou elle a 
charge ses donnyes fonctionnelles secretes, contre 
toute tentative de lecture ou d'ycriture provenant 
du dyroulement d'une autre application, que ces 
tentatives proviennent d'une erreur de program - 

40 mation de I'entity ayant ymis cette autre application 
ou qu'elles proviennent de la programmation illicite 
d'un fraudeur.On doit se rendre compte qu'il serait 
illusoire de confier a une plurality d'entit^s sus- 
ceptibles de charger diverses applications, des 

45 secrets de programmation relatifs au chargement 
des applications en espyrant que ces secrets ne 
parviennent jamais dans les mains de personnes 
mal intentionnyes. Une solution ne peut etre envi - 
sagye dans cette direction d'autant plus qu'une 

so entity bien qu'autorisye mais maladroite peut 
ymettre une application contenant une erreur de 
programmation aboutissant a la destruction d'une 
donpye contenue dans une application etrangere a 
la sienne. 

55 L'invention vise tout particulierement le cas 

d'un microcircuit pour carte a puce du type multi - 
applications, dans lequel un haut niveau de s6- 
curity est maintenu malgry que la carte soit fabri - 
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qu^e dans un etant vierge et qu'elle soit suscepti - 
ble d'etre charg£e, dans un ordre indifferent, par 
des entites emettrices d'applications qui sont in- 
dependantes les unes des autres. En quelque 
sorte, le microcircuit souhaite devrait disposer de 
verrous mobiles mais inviolables que ce soit en 
cours de chargement, de fonctionnement, ou par 
renvoi de signaux quelconques sur les acces 
d'entree- sortie. 

L'invention k pour but de fournir une solution k 
ce problems technique. 

En effet, selon l'invention, un microcircuit pour 
carte k puce, d'un type conforme au paragraphe 
introductif, est caracterise en ce que, en vue d'un 
chargement et d'une exploitation de programmes 
d'applications ind£pendants les uns des autres, le 
microcircuit est muni d'une unite centrale de mi - 
croprocesseur, d'une memoire k lecture seule 
(ROM) contenant notamment des routines fonc- 
tionneiles exclusivement ex^cutables par I'unite 
centrale et sous sa d£pendance, en ce que dans 
I'espace d'adressage de la memoirs programmable 
sont d£limit£es une zone dite de repertoire et une 
zone dite des applications, lesquelles zones sont 
exclusives i'une de I'autre, en ce que la zone de 
repertoire contient une table repertoire ou les 
adresses de debut et de fin ainsi qu'un code de 
reference de chacun des programmes d'applica - 
tions susceptible d'etre charge dans une portion de 
la zone des applications, sont inscrits au fur et k 
mesure du chargement desdits programmes et en 
utilisant une desdites routines fonctionnelles, en ce 
que le circuit de controls d'adressage est agence 
pour inhiber les commandes d'ecriture et de lec- 
ture de la m£moire programmable pour des 
adresses qui se situent k I'exterieur de I'intervalle 
defini par les valeurs limites de debut et de fin 
d'une application designee preatablement sur les 
acc£s d'entree- sortie, limites qui sont memorisees 
dans des registres verrouillables, appeies registres 
de limites tandis que la voie dite d'autorisation 
prioritaire comporte des moyens pour, s'affranchir 
de Tinhibition precise en autorisant recriture et la 
lecture de la zone de repertoire k la condition 
exclusive que ces operations soient effectuees au 
moyen d'une desdites routines fonctionnelles du- 
rant une etape operatoire predeterminee durant 
laquelle les registres contenant les valeurs limites 
sont deverrouilies. 

Ainsi, dans le cas general ou un programme 
d'application est d6\k charge dans la carte et ap - 
peie par I'intermediaire les moyens d'acces 
entree - sortie, un protocole standard de recon- 
naissance de ('utilisation pr6vu parmi les routines 
fonctionnelles est execute. Apr&s quoi, une autre 
routine commands une recherche dans la table 
repertoire, les valeurs limites d'adresse corres- 
pondent au programme d'application demande, 
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identifie dans ladite table par son code de refe- 
rence, et ces valeurs sont chargees dans les re - 
gistres de limites, deverrouilies durant cette etape 
initiate de fonctionnement. 

5 Le programme d'application demande est en - 

suite lance et simultanement, les registres de li- 
mites sont verrouilies de sorte que les demandes 
d'acces en ecriture ou en lecture qui designeraient 
la me moire programmable en dehors de la zone 

70 d'adresses comprise entre les valeurs limites me - 
morisees, resteront sans effet, par exemple jusqu'& 
ce que le microcircuit soit mis hors tension. La voie 
d'autorisation prioritaire est en effet refermee. De 
cette maniere, un programme d'application est seul 

75 k pouvoir lire ou ecrire dans la zone d'adresse qui 
lui est affectee et qui a ete fix£e lors du charge - 
ment. Les autres programmes d'applications sont 
proteges contre toute tentative de lecture ou 
d'ecriture. 

20 En ce qui concerne le chargement de tout 
nouveau programme d'applications au sein de la 
carte, la securite* provenant de I'absence d'interfe - 
rence avec d'autres zones de la memoire pro- 
grammable est assuree par des moyens similaires. 

25 Toute demande de chargement d'un pro- 
gramme d'application sur les moyens d'acces 
entree - sortie fait I'objet d'un protocole standard 
engage en liaison avec une routine fonctionnelle 
specialises contenue dans la memoire k lecture 

30 seule. Le code de reference de I'application ainsi 
que I'espace memoire requis doivent etre annon - 
ces durant ce protocole. Une routine fonctionnelle 
specifique a pour effet de recherchsr dans la table 
repertoire quelle est la premiere adresse disponible 

35 dans la zone des applications (I'adresse qui suit 
I'adresse de fin la plus eleven des programmes 
d'applications 66\k charges ou la premiere adresse 
de la zone des applications lorsque la carte est 
vierge). L'adresse de fin de I'application demandee 

40 est calcuiee k partir de la demande d'espace m6 - 
moire annoncee precedemment. Lorsque cette 
adresse de fin d'application est compatible avec 
I'espace memoire de la zone des applications, les 
valeurs limites d'adresses de debut et de fin ainsi 

45 que le code de reference de I'application sont alors 
inscrits dans la table repertoire et ces valeurs li- 
mites sont chargees dans les registres de limites, 
toujours par le moyen d'une routine fonctionnelle 
preetablie et intangible. 

so Durant ces etapes qui precedent le charge- 
ment, les registres de limites sont deverrouilies, et 
ils peuvent le rester durant le chargement du pro - 
gramme d'application qui s'ensuit. La securite re - 
cherchee est neanmoins conserves par le fart que 

55 le chargement du programme d'application est ef- 
fectue sous le contrdle de I'unite centrale et par 
I'effet d'une routine fonctionnelle preetablie et sOre 
qui exclut toute modification de contenu des re - 
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gistres de li mites. 

On peut aussi preVoir un verrouillage de ces 
registres qui soit command^ par programmation 
juste avant le chargement. 

Toute tentative de chargement en dehors des 5 
limites d'adresses etablies pnic6demment restera 
sans effet L'operation de chargement peut etre 
compile, si on le juge necessaire, par une routi- 
ne de verification des donn^es charg§es, une v4 - 
rification de signature, un test de parity. ..etc... mais io 
de telles operations n'auront pas pour effet d'ac- 
croitre de maniere significative la s£curite de 
fonctionnement du microcircuit selon I'invention. 

La voie d'autorisation prioritaire peut etre 
commandee de diff^rentes manieres en appliquant 75 
des conditions logiques appropriees et en fonction 
du deVoulement des Stapes op^ratoires qui suivent 
la mise sous tension du microcircuit. 

Toutefois, selon un mode de mise en oeuvre 
pr£fe>6 de I'invention, qui offre toute garantie du 20 
point de vue de la s£curite\ le microcircuit se 
caracterise en ce qu'il comporte une bascule bis- 
table, piac£e dans un premier etat exclusivement 
lors d'une mise sous tension du microcircuit, puis 
placde dans un deuxieme etat oppose au premier, 25 
des qu'un compteur ordinal associe* & I'unite cen - 
trale, contient une valeur d'adresse comprise dans 
I'espace d'adressage de la memoire programma- 
ble, et en ce que cette bascule bistable deiivre un 
signal de verrouillage/deverrouillage pour la com - 30 
mande de verrouillage des registres de limites et 
pour la commande de la,voie d'autorisation priori- 
taire. 

Du fait qu'il est lie* au compteur ordinal, le 
signal de verrouillage/deverrouillage fournit un 35 
moyen inviolable par un programme d'application 
quelconque pour le verrouillage des registres de 
limites et de la voie d'autorisation prioritaire, bien 
que la bascule bistable reste par sa nature un 
element reversible dans le temps. . aq 

Comme les routines fonctionnelles qui ont pour 
objet de lire et/ou ecrire dans la table repertoire 
sont inscrites dans la memoire & lecture seule, le 
compteur ordinal pointe cette memoire pour les 
exgcuter pas k pas. 45 

II suffit done de placer ('execution de ces rou - 
tines dans des etapes operatoires qui precedent 
toute execution de programme inscrit dans la me - 
moire programmable. La voie d'autorisation priori - 
taire est encore ouverte tant qu'il s'agit de routines 50 
executes sous le controle de I'unite centrale. Des 
que le compteur ordinal sera charge d'une adresse 
designant la memoire programmable, le signal de 
verrouillage/deverrouillage sera aussitdt place dans 
son etat realisant le blocage, verrouillant les regis - 55 
tres de limites et interdisant I'acces & la table 
repertoire. 
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En pratique ceci peut avantageusement etre 
realise dans un microcircuit caracterise en ce que 
le circuit de controle d'adressage comporte une 
porte OU dite de validation, dont la sortie com- 
mande la transmission des signaux d'ecriture et de 
lecture de la memoire programmable, en ce qu'une 
premiere entree de cette porte de validation regoit 
un signal resultant de la comparison de toute 
adresse appeiee avec le contenu des registre de 
limites, et une autre entree par laquelle s'effectue 
Cauterisation prioritaire, regoit un signal resultant 
du produit logique entre le signal de 
verrouillage/deverrouillage et le signal de sortie 
d'un decodeur d'adresses reconnaissant les seules 
adresses de la zone de repertoire. 

Jusqu'& present on a consideYe que I'espace 
d'adressage de la memoire programmable etait 
protege dans les conditions precitees relatives & la 
zone de repertoire et la zone des applications. 

It peut cependant etre utile de prevoir en outre 
une certaine zone de I'espace d'adressage de la 
memoire programmable qui soit librement acces- 
sible par tout programme d'application, par exem - 
pie pour y placer provisoirement des resultats de 
traitement ou pour transmettre des donnees d'une 
application h une autre. 

Sans amoindrir la s^curite, cette facility peut 
etre obtenue aisement par une legfcre modification 
du circuit de controle d'adressage precedemment 
detini. Selon ce mode de mise en oeuvre, un 
microcircuit selon I'invention est caracterise en ce 
qu'une zone dite "publique" est en outre pr§vue 
dans I'espace d'adressage de la memoire pro- 
grammable, zone qui est dtstincte de la zone de 
repertoire et de la zone des applications, et en ce 
que le circuit de controle d'adressage comporte un 
decodeur d'adresse suppiementaire, reconnaissant 
les seules adresses de la zone publique, qui 66\\ - 
vre en sortie un signal applique i une entree 
suppiementaire de la porte OU de validation. 

La description qui va suivre en regard des 
dessins annexes, donnes & titre d'exemples non 
limitatifs, fera bien comprendre en quoi consiste 
I'invention et comment elle peut etre realisee. 
La figure 1 represente un schema de principe 
d'un microcircuit selon I'invention, 
la figure 2 est un schema - bloc d'une portion 
du microcircuit deiivrant un signal de 
verrouillage/deverrouillage et, 
la figure 3 iilustre schematiquement I'organisa- 
tion d'une zone particuliere de la memoire pro- 
grammable. 

La figure 1 represente le schema general et 
simplifie d'un microcircuit selon I'invention. 

Sur cette figure, et pour plus de clarete, les 
elements qui ne concernent pas directement Tin - 
vention n'ont pas ete representes. Le microcircuit 
comporte une unite centrale 10 de microproces- 
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seur, une memoire vive 11, une memoire a lecture 
seule 12, une memoire programmable 13 par 
exemple une EEPROM ainsi qu'un circuit de 
contrdle d'adressage 14 de la memoire program- 
mable 13. Les elements precit€s sont relics entre 
eux par un systeme de bus 15 vghiculant les 
adresses et les donnees entre ces diff£rents 6\6 - 
ments. Pour plus simplicity le systeme de bus 15 a 
ete* repr^sente par une liaison unique bien qu'on 
puisse, selon les cas, utiliser un bus d'adresses et 
un bus de donnees qui soit s^pargs Tun de Pautre. 
Com me cela est de pratique courante, le systeme 
de bus 15 peut encore etre un bus unique sur 
lequel les adresses et les donnees sont multi- 
plex^es temporellement. A I'unite centrale 10 sont 
associes des moyens d'acces entree - sortie 16, 
moyens qui sont isol£s du systeme de bus 15 de 
maniere a garantir un acces contrdle par I'unite 
centrale 10 aux zones sensibies du microcircuit 
contenant des donnees a proteger. 

Le circuit de contrdle d'adressage 14 regoit de 
I'unite centrale 10 un ensemble de liaisons de 
commando 20 parmi lesquelles figurent essentiel - 
lement les commandos d'ecriture W de lecture R 
et d'effacement E lorsqu'elles sont destinees a la 
memoire programmable 13. 

Les commandos de lecture et d'ecriture pour la 
memoire vive 11 et les commandes de lecture 
pour la memoire a lecture seule 1 2, n'ont pas 6x6 
representees, pour plus de clarte de la figure et du 
fait qu'elles n'interferent pas avec Pinvention. Les 
commandes W, R et E destinies a la memoire 
programmable 13 peuvent etre inhibees ou vali- 
d^es par le circuit de contrdle d'adressage 14 dans 
des conditions qui seront expliqu€es ci-apres. 
Conformement a une pratique en usage dans les 
microcontroleurs, la memoire a lecture seule 12 et 
la memoire programmable 13 font partie d'un 
me me systeme d'adressage tandis que la memoire 
vive 1 1 est adressee de maniere distincte et ex - 
elusive de Padressage des me* moires 12 et 13. 
Dans Pespace d'adressage de la memoire pro- 
grammable 13 sont delimiters une zone de reper- 
toire ZR et une zone des applications ZA, zones 
qui sont exclusives Tune de Pautre et qui sont 
definies une fois pour toutes par construction. 

Initialement les zones ZR et ZA sont vierges. 
Le microcircuit peut etre charge de programmes 
duplications independant les uns des autres dans 
un ordre et a des moments qui sont indifferents. 
Au fur et a mesure du chargement desdits pro- 
grammes ceux-ci vont §tre inscrits successive - 
ment dans des zones distinctes ZAi , ...ZA|, ...ZA n 
qui sont adjacentes et qui remplissent progressi - 
vement la zone des applications ZA. 

Bien entendu, chaque zone ZA, d'une applica- 
tion determinee peut egalement contenir des don - 
n6es (autres que des codes operatoires) qui sont 



propres a cette application et/ou des emplace- 
ments memoire destines a recevoir des resultats 
de traitement. Selon Pinvention la zone de reper- 
toire ZR contient une table repertoire ou les 

5 adresses de debut et de fin ainsi qu'un code de 
reference de chacun des programmes duplica- 
tions charges dans la zone des applications sont 
inscrits lors du chargement desdits programmes. 
Ainsi, un i 6me programme d'application charge dans 

70 la zone ZA, entre les adresses ZA« et ZAj h respe - 
ctivement de debut et de fin du programme d'ap - 
plication i a ete charge au cours d'un protocole au 
cours duquel les adresses ZA,, et ZA, h ont ete 
prealablement determinees et chargees dans la 

75 table repertoire de la zone de repertoire ZR ac- 
compagnes d'un code reference du programme 
d'application i. Le protocole de chargement qui 
vient d'etre mentionne utilise une desdites routines 
fonctionnelles inscrites de maniere immuable dans 

20 la memoire a lecture seule 12. 

Le circuit de controle d'adressage 14 est 
agence pour inhiber les commandes de lecture (R) 
d'ecriture (W) et d'effacement (E) destinees a la 
memoire programmable 13 pour des adresses qui 

25 se situent a Pexterieur de Pintervalle defini par les 
valeurs limites de debut ZA,, et de fin ZA, h d'une 
application ZA, designee prealablement sur les 
acces d'entree/sortie 1 6. Pour ce faire, le systeme 
de bus 15 est partage des I'entree dans le circuit 

30 de contrdle d'adressage 14 en un bus de donnees 

21 et un bus d'adresses 22. Le bus de donnees 21 
est applique en parallele sur deux registres ver- 
rouillables dits registres de limites 25, 26 respec- 
tivement, ou les adresses de debut et de fin d'une 

35 application en cours de traitement peuvent etre 
memorisees et verrouiliees au moyen d'un signal 
de verrouillage/deverrouillage (LOC) provenant 
d'une borne 60. Le bus d'adresses 22, interne au 
circuit de controle d'adressage 14, est applique en 

40 parallele a deux comparateurs 28, 29 respective - 
ment associes aux registres de limites 25 et 26. Le 
comparateur 28 deiivre un signal d'autorisation 
lorsque Padresse courante sur le bus d'adresses 

22 est superieure ou egale a Padresse de debut 
45 memorisee dans le registre de limites 25 tandis 

que le comparateur 29 deiivre un deuxieme signal 
d'autorisation lorsque Padresse courante sur le bus 
d'adresse 22 est inferieure ou egale a Padresse 
limite de fin d'application memorisee dans le re- 

so gistre 26. Les deux signaux d'autorisation deiivres 
en sortie des comparateurs 28 et 29 sont appliques 
aux deux entrees d'une porte ET 30 dont la sortie 
31 presente un signal d'autorisation lorsque 
Padresse courante presentee sur le bus d'adresse 

55 22 est comprise dans les limites des adresses 
memorisees dans les registres 25 et 26. Le signal 
d'autorisation present a la sortie 31 de la porte 30 
est applique via une porte OU 32, dite de valida- 
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tlon, a Tune des entries de trois portes ET 35, 36, 
37 dont I'autre entree de chacune d'elle regoit 
respectivement les commandes de lecture (R) 
ecriture (W) et d'effacement (E). Ces commandes 
ne sont done transmises a la memoire program - 
mable 13 que lorsque les portes ET 35, 36, 37 sont 
passantes e'est-a-dire lorsque I'adresse cou- 
rante pr^sente sur le bus d'adresses 22 est com - 
prise ou 6ga!e aux limites d'adresses memorisees 
dans les registres 25 et 26 et au contraire ces 
commandes sont inhibees dans le cas ou I'adresse 
courante est ext£rieure a ces valeurs limites. 

La porte OU 32 constitue une partie de ce qui 
a ete appele precedemment voie d'autorisation 
prioritaire, du fait qu'elle comporte une deuxfeme 
entree 40 sur laqueile est applique un signal d'au - 
torisation durant une etape op^ratoire pr£d6termi - 
n£e qui suit toute mise sous tension du microcir- 
cuit. 

Pour rSaliser ladite voie d'autorisation priori- 
taire, le signal de verrouillage/deverrouillage 
(LOC) est invars^ par un inverseur 41 et applique a 
une des deux entries d'une porte ET 42. Sur 
I'autre entree de cette porte ET 42 est applique le 
signal de sortie d'un decodeur d'adresses 43 re - 
connaissant les seules adresses de la zone de 
repertoire (ZR) et fournissant a la porte ET 42 un 
signal d'autorisation lorsque I'adresse courante 
presentee sur le bus d'adresses 22 est comprise 
dans I'espace d'adressage de la zone de repertoire 
(ZR). La porte ET 42 effectue ainsi le produit 
logique entre le signal de 
verrouillage/deverrouillage (LOC) et le signal de 
sortie du decodeur d'adresses 43 pour fournir un 
signal d'autorisation prioritaire a I'entree 40 de la 
porte de validation 32. Le decodeur d'adresses 43 
qui reconnatt uniquement des adresses de la zone 
de repertoire (ZR) de la memoire programmable 13 
peut etre d'un type trfcs simple lorsque le nombre 
d'octets de la zone de repertoire (ZR) peut s'ex - 
primer par une puissance enti&re de deux telle 
qu'une valeur de 256 octets ou 512 octets etc. A 
titre d'exemple, la zone de repertoire peut avoir 
une adresse de debut exprimee en hexadecimal 
par la valeur 8000 et I'adresse de fin de cette zone 
par I'adresse hexadecimale 80FF. 

Le microcircuit represente a la figure 1 com - 
porte encore une disposition optionnelle selon la - 
quelle une zone dite "publique" ZB est prevue 
dans I'espace d'adressage de la memoire pro- 
grammable 13, zone qui est distincte de la zone de 
repertoire ZR et de la zone des applications ZA et 
que Ton a fait figurer a titre d'exemple entre les 
zones ZR et ZA et adjacente a celles-ci. Du fait 
que Ton a pnSvu un accfes inconditionnel a cette 
zone publique ZP, la porte de validation 32 com - 
porte une trots&me entree 50 par laqueile est 
applique un signal de validation provenant d'un 



decodeur d'adresses 51 similaire au decodeur 
d'adresses 43 a I'exception prfcs qu'il ne reconnatt 
que les seules adresses de la zone publique ZP de 
la memoire programmable 13. 

5 Ainsi que cela a 66\h e\6 mentionne, le signal 

de verrouillage/deverrouillage (LOC) est place dans 
un etat de deverrouillage (LOC = 0) durant une 
, etape operatoire predeterminee qui suit toute mise 
sous tension du microcircuit. II peut etre genere 

io par tous syst&mes logiques convenables penmet- 
tant d'autoriser le chargement des registres de 
limites 25 et 26 et de debloquer la porte ET 42 
pour permettre la lecture et/ou J'6criture de la table 
repertoire situ^e dans la zone de repertoires ZR. 

15 Selon un mode de mise en oeuvre de Tinven - 
tion particulierement avantageux pour la securite 
eievee qu'il procure, le signal de 
verrouillage/deverrouillage (LOC) est produit en 
liaison avec le contenu d'un compteur ordinal tel 

20 qu'il est generalement connu et associe a une 
unite centrale de microprocesseur. 

On se reporte maintenant a la figure 2 pour la 
description de cette portion du microcircuit. 

Sur cette figure, on a represente un compteur 

25 ordinal 55 qui fait partie de I'unite centrale 10 et 
qui permet ('execution pas a pas de routines 
fonctionnelles contenues dans la memoire a lecture 
seule 12. Cette disposition est par ailleurs cfassi- 
que dans tous les microcontrdleurs ou micropro - 

30 cesseurs et ne necessite pas, de ce fait, une 
description detaillee. Le compteur ordinal 55 est 
relie a un decodeur 56, 57 qui actionne a sa sortie, 
via une porte OU 66 une bascule bistable 58, par 
exemple de type RS, lorsque le contenu du 

35 compteur ordinal 55 de passe une certain e valeur 
d'adresse qui dans I' exemple il lustre a pour limite 
la valeur hexadecimale 7FFF. Cette limite 
d'adresse correspond au cas ou la memoire pro - 
grammable a son adresse la plus basse exprimee 

40 en hexadecimal par la valeur 8000. Une routine 
fonctionnelle, par ailleurs classique en mature de 
microcontrdleur, effectue la remise a zero d'un 
certain nombre de registre et dans le cas precis, 
applique un signal de remise a zero de la bascule 

45 bistable 58 sur son entree de remise a zero 59. La 
bascule bistable 58 deiivre en definitive le signal 
de verrouillage/deverrouillage (LOC) sur la borne 
60 representee egalement a la figure 1 , a I'entree 
du circuit de controle d'adressage 14. 

so A la suite d'une mise sous tension du micro - 
circuit, et tant que I'unite centrale 10 execute les 
routines fonctionnelles contenues dans la memoire 
a lecture seule 12, le compteur ordinal 55 designe 
des adresses de programme qui sont relatives a 

55 cette me me memoire a lecture seule et la bascule 
bistable 58 deiivre un signal de deverrouillage 
(LOC = 0). La table de repertoire peut etre lue ou 
ecrite sous le contrdle de I'unite centrale 10 et les 



6 



> 



11 



EP 0 540 095 A1 



12 



registres de limites 25, 26 peuvent etre charges 
par cette m§me unite centrale. Au contraire, des 
lors qu'un programme duplication est appeie (de 
sorte que I'adresse contenue dans le compteur 
ordinal 55 d£passe n^cessairement I'adresse 5 
hexadecimale 7FFF, donnee comme limite dans 
I'exemple) la bascule bistable 58 est plac^e dans 
l'6tat oppose au premier etat et deiivre un signal 
de verrouillage sur la borne 60 (LOC = 1). Les 
registres de limites 25 et 26 ainsi que la voie 10 
d'autorisation prioritaire seront d^sormais verrouil - 
l§s jusqu'a la prochaine mise hors tension du mi- 
crocircuit. Comme on le voit cette disposition offre 
toute se'curite' pour garantir une absence d'interfe* - 
rence entre les diffdrents programmes d'applica- 75 
tions susceptibles d'etre charges dans la zone des 
applications ZA. 

La porte OU 66 permet egalement une variante 
de fonctionnement selon laquelle le signal de ver - 
rouillage (LOC = 1) peut etre produit par une 20 
routine sp^cifique contenue dans la m^moire ROM 
12, et done meme si le contenu du compteur n'a 
pas encore de passe" la valeur limite de 7FFF. La 
routine fonctionnelle pnSvue a cet effet impose a 
I'unite centrale 10 d'emettre un signal de com- 25 
mande sur une liaison 67 qui est appliquee a une 
deuxieme entree de la porte OU 66. On peut done 
ainsi emettre un signal de verrouillage par pro- 
grammation qui subsistera jusqu'a la prochaine 
remise a zero. Cette disposition permet d'accrottre 30 
encore la securite pendant le chargement d'un 
nouveau programme d'application et pendant 
I'ex^cution d'une application qui ne ferait appel 
qu'a des routines contenues dans la m£moire ROM 
12 et dont la zone ZAj reserv^e dans la m€moire 35 
programmable ne contiendrait que des donnees (et 
aucun code op^ratoire). 

A I'aide de la figure 3, on va expliquer succin- 
tement comment la zone de repertoire ZR de la 
m^moire programmable 13 peut etre organised. La 40 
figure 3 se retere par ailleurs a un exemple dont 
les valeurs sont purement arbitraires et n'ont pas 
d'autre but que de rendre les explications plus 
claires. 

On suppose que la zone repertoire de la me - 45 
moire programmable 13 commence a I'adresse 
hexadecimale 8000 et finit a I'adresse 80FF. Dans 
cette zone d'un volume de 256 octets, on peut 
prevoir, si on le desire, une portion designee par 
ZID destined a recevoir des donnees d'identifica - 50 
tion de la carte, du propri&aire de celle-ci et des 
cies. En dehors de la zone d'identification ZID se 
situe la table de repertoire TR proprement dite qui 
debute a I'adresse INI et s'etend jusqu'a I'adresse 
hexadecimale 80FF. Comme indique sur la figure, 55 
la table repertoire TR contient les inscriptions 
successives d'un premier programme charge, dont 
le code de reference est appeie "PR-APP- A", 



d'une longueur de 350 octets, dont I'adresse 
hexadecimale de debut d'execution de programme 
est egale a 8200 ainsi que I'adresse de debut de 
zone, et I'adresse de fin de zone egale a 835D, 
puis un programme reference "PR-APP-B" 
d'une longueur de 250 octets, ayant pour adresse 
de debut d'execution de programme ia valeur 
hexadecimale 8365, pour I'adresse de debut de 
zone, 835E pour I'adresse de fin 8457, et enfin un 
programme reference "PR-APP-C", d'une lon- 
gueur de 180 octets, ayant pour adresse de debut 
d'execution de programme la valeur hexadecimale 
8460 pour I'adresse de debut de zone, 8458 et 
pour adresse de fin la valeur 850C. En effet, les 
adresses de debut d'execution de programme, 
comme I'indique cet exemple, ne coincident pas 
necessairement avec I'adresse de debut de zone 
allouee au meme programme, mais elles sont ne - 
cessairement comprises dans ladite zone allouee. 

On va decrire tout d'abord le cas ou un pro- 
gramme d'application d£ja charge dans la carte est 
appeie sur les moyens d'acces d'entree/sortie. 

Toute demande d'execution d'un programme 
d'application fait I'objet d'une procedure qui peut 
se decomposer en 5 etapes principales : 

- une etape d'initialisation qui peut inclure une 
procedure d'identification de la carte et son 
utilisateur, 

- une procedure de demande de I'application 
annoncee sur les moyens d'entree- sortie, 

- une procedure de recherche dans la table de 
repertoire TR pour determiner si ^application 
demandee existe, et dans i'affirmative, le 
chargement des donnees specifiques de 
I'application preiev^es dans cette table, 

- le chargement des registres de limites, 

- et enfin I'execution proprement dite du pro - 
gramme d'application demande. 

Des la mise sous tension du microcircuit, la bas - 
cule bistable 58 est remise a zero en meme temps 
qu'un certain nombre de registres et notamment le 
compteur ordinal 55. Apres un eventual protocoie 
de reconnaissance mettant en jeu des donnees 
d'identification contenues dans la portion d'identi - 
fication ZID de la zone repertoire ZR, un pro- 
gramme d'application par exemple celui reference 
"PR-APP-B" est appeie. 
Sous I'effet d'une routine preetablie, I'unite centrale 
10 effectue une recherche dans la table repertoire 
TR de maniere a determiner si un tel programme 
d'application est present. Dans I'affirmative les va- 
leurs d'adresse de debut et de fin de ce program - 
me d'application, dans I'exemple les adresses 
hexadecimales 835E et 8457 respectivement, sont 
preievees dans la table de repertoire TR et toujours 
sous I'effet d'une routine preetablie ces valeurs 
limites sont chargers dans les registres des limites 
25 et 26 respectivement. Jusqu'a present le fonc - 
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tionnement du microcircuit n'a fait appel qu'& des 
routines situ€es dans la memoire & lecture seule 
12 de sorte que le compteur ordinal n'a jamais 
franchi la limite des adresses designant la memoire 
programmable 13 soit dans notre exemple une 
adresse supe>ieure k la valeur hexadecimale 7FFF. 
Dans T6tape op^ratoire qui suit et qui consiste k 
exbcuter le programme appele\ ie compteur ordinal 
55 est charge avec I'adresse de debut d'exScution 
du programme d f application appeie, par exemple 
I'adresse hexad£ciame 8365. Ceci entrathe un 
changement d'etat de la bascule bistable 58 et 
procure sur la borne 60 un signal de verrouillage 
(LOC = 1 ). Ce signal a pour effet de verrouiller les 
registres de limites 25 et 26 et de bloquer la voie 
d'autorisation prioritaire formee par la branche 
comportant I'inverseur 41, la porte ET 42 et I'en- 
tree 40 de la porte de validation 32. De*sormais les 
operations d'ecriture, de lecture et d'effacement de 
la memoire programmable ne peuvent plus etre 
ex6cut§es que dans la seule portion comprise dans 
les limites de debut et de fin du programme appeie 
ou dans la zone publique ZP. Cet acces sglectif va 
persister jusqu'St la mise hors tension du microcir- 
cuit. Les operations d'ecriture et de lecture dans la 
zone dite publique ZP restent possibles au moyen 
du signal d'autorisation present sur l'entr€e 50 de 
la porte de validation 32 et provenant du ddcodeur 
d'adresse 51 qui reconnalt les adresses corres- 
pondent k cette zone ZP. 

On en vient maintenant k dScrire le fonction - 
nement du microcircuit dans le cas ou un pro- 
gramme d'application doit etre charge* dans la 
memoire programmable 13. Des la mise sous ten- 
sion du microcircuit, une etape d'initialisation est 
engag€e qui est essentiellement similaire k celle 
66$ mentionn^e pour I'execution d'un programme 
d'application. Dans une seconde etape, et sous le 
controls d'une routine fonctionnelle pr^tablie, le 
code de reference du programme k charger est 
annonce" sur les entries -sorties ainsi que le vo- 
lume de memoire n^cessaire k ce programme ex - 
prim4 par exemple en nombre d'octets. Dans une 
troisieme etape opeVatoire, et egalement sous ref — 
fet d'une routine fonctionnelle preetablie, une re- 
cherche est effective dans la table repertoire TR 
contenue dans la zone de repertoire ZR de ma- 
niere k determiner si le programme demands a 
66\k ete charge et sinon quelle est la derniere 
adresse limite de fin de programme inscrite dans la 
table. Cette adresse correspond egalement k 
I'adresse occupee la plus eievee de la zone ZA 
puisque les programmes ont ete charges succes - 
sivement k des adresses croissantes. Dans 
I'exemple il s'agit de la valeur hexadecirhale 850C. 
La m§me routine fonctionnelle determine d'une 
part la valeur d'adresse qui suit immediatement 
c'est-&-dire I'adresse hexadecimale 850D qui 



sera pr£vue comme valeur limite de debut du 
nouveau programme k charger et calcule d'autre 
part quelle sera I'adresse de fin de programme k 
charger compte tenu du volume de memoire an - 

s nonce dans la seconde etape. Dans une quatrieme 
etape, I'unite centrale effectue un test pour deter- 
miner si I'adresse de fin de programme ainsi cal - 
cuiee est compatible avec I'adresse la plus eievee 
de la zone des applications ZA, puis sous I'effet 

70 d'une routine preetablie, les valeurs limites de de - 
but et de fin de programme ainsi determiners sont 
chargers dans les registres de limites 25 et 26. Du 
fait que jusqu'& present I'unite centrale a effectue 
des routines fonctionnelles situees dans ia me- 

75 moire k lecture seule 12, le compteur ordinal n'a 
jamais franchi la limite des valeurs d'adresse qui 
concernent la memoire programmable 13. Ainsi le 
signal de verrouillage/deverrouillage est dans son 
etat de deverrouillage (LOC = 0) ce qui a permis 

20 le chargement des registres des limites 25 et 26 
ainsi que la lecture de la table de repertoire au 
moyen de la voie d'autorisation prioritaire 41 , 42 et 
32. Dans une cinquieme etape et sous I'effet d'une 
routine fonctionnelle, I'unite centrale 10 complete la 

25 table repertoire de la zone de repertoire ZR en 
inscrivant k la suite des references 66'\k presentes, 
le code de reference, les valeurs limites d'adresses 
de debut et de fin precedemment determinees et 
qui concernent le programme d'application en voie 

30 de chargement, ainsi que i'adresse de debut 
d'execution de ce programme. 

Une sixieme etape operatoire, qui suit, 
concerne essentiellement le chargement dudit 
programme, chargement qui ne peut etre accompli 

35 qu'& I'interieur des limites fixees par les valeurs 
d'adresses de debut et de fin memorisees dans les 
registres des limites 25 et 26. Pendant ce charge - 
ment les registres de limites 25 et 26 peuvent ne 
pas etre verrouilies (LOC = 0) mais lesdrts regis - 

40 tres effectuent le controle des operations d'ecriture 
de la m§me maniere que s'ils avaient ete verrouil - 
ies. La securite est neanmoins maintenue du fait 
que le chargement est execute sous le contrdle de 
I'unite centrale 10 par I'effet d'une routine fonc- 

45 tionnelle qui ne peut §tre modifies par un utilisa- 
teur. Toutefois, il est egalement possible d'activer 
la bascule 58 par programmation au moyen d'un 
signal transmis par la liaison 67 & la porte OU 66. 
Dans ce cas les registres de limites peuvent etre 

so verrouilies lors du chargement. Toute tentative de 
chargement d'un programme d'application d'une 
longueur superieure au volume de memoire an- 
nonce restera inefficace par I'effet du contrdle 
exerce par les registres de limites 25 et 26 et de la 

55 porte ET 30. 

Si on le desire retape de chargement du pro - 
gramme peut etre suivie par une verification des 
donnees chargees, une verification de signature 
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finale, un test de parity, et.... II est ais£ de detecter 
une tentative de chargement d'un programme de 
longueur sup£rieure a la longueur annonc6e du fait 
que la ou les dernieres donn^es presentees au 
chargement ne sont pas en fait enregistnSes dans 
la memoire programmable de sorte qu'une v^rifi - 
cation de ces donn£es finales revele la tentative 
d'un chargement abusif qu'il soit accidentel ou 
frauduleux. 

En se r€f§rant a nouveau a la figure 1, un 
dispositif additionnel pour la signalisation d'une 
anomalie de fonctionnement va maintenant etre 
decrit Ce dispositif additionnel comporte une porte 
ET 62 a deux entries, une porte OU 63 a 3 
entries et un inverseur 64. 

L'inverseur 64 regoit en entree le signal de 
sortie de la porte de validation 32, et le transmet 
apr&s inversion, a une entree de la porte ET 62. 

La porte OU 63 a sa sortie connects a I'autre 
entree de la porte ET 62 et regoit en entree les 
trois signaux de commando R, W, E destines a la 
memoire programmable 13, en formant ainsi la 
somme logique de ces signaux de commands 

Lorsque Tune de ces operations est demandee, 
le signal en sortie de la porte OU 63 est a l'£tat 
haut. Simultanement, si aucune des conditions 
d'autorisation n'est rSalisee, ce qui produit un si - 
gnal a I'etat bas en sortie de la porte OU 32, la 
porte ET 62 est alors activee et produit en sortie 
un signal renvoye a Tunite centrale 10, par exem- 
pie un signal d'interruption (INT = 1). 

Ainsi, dans le cas d'utilisation d'une interrup- 
tion, une anomalie de fonctionnement et plus par - 
ticuli&rement une demande non autoris£e d'acces 
a la memoire programmable 13 aboutira a une 
interruption de fonctionnement du microcircuit 
(interruption non masquable) et on peut, si on le 
desire, produire un message divertissement sur le 
terminal d'exploitation de la carte. 

Le signal INT qui est produit en cas d'anomalie 
peut §tre utilise pour op^rer toute modification 
desirable du fonctionnement du microcircuit : par 
exemple invalider le programme qui a produit 
I'anomalie, voire invalider totalement le fonction- 
nement de la carte. 

Une consequence avantageuse de ('invention 
est que seules les routines fonctionnelles incrites 
dans la memoire a lecture seule devront §tre ex- 
tensivement testes et approuvdes alors que les 
programmes duplications pourront etre cr66s par 
diverses entites, sous leur propre responsabilite, et 
sans risque d'interterence indue entre les applica- 
tions. 

Le microcircuit selon I'invention offre done une 
parfaite securite pour une utilisation de carte a 
puce multi - applications. 



Revendications 

> 

1. Microcircuit pour carte a puce comprenant 
entre -autres : des moyens d'acefcs entree - 

5 sortie, au moins une memoire qui est pro- 

grammable et accessible par un espace 
d'adressage a adresses cons^cutives, un cir- 
cuit de contrdle d'adressage de cette memoire 
programmable determinant soit une inhibition, 

10 soit une validation des commandes d'^criture 

et/ou de lecture par la comparaison de 
I'adresse demandee avec deux valeurs limites 
de debut et de fin d'une zone particuli&re 
d'adresses, limites qui sont m£moris£es au 

75 sein du circuit de contrdle d'adressage iequel 
circuit comporte egalement une voie d'autori - 
sation prioritaire permettant de s'affranchir 
temporairement de ladite inhibition dans des 
circonstances pr£d€termin£es et particulidres, 

20 caracterise en ce que, en vue d'un chargement 

et d'une exploitation de programmes d'appli - 
cations independants les uns des autres, le 
microcircuit est muni d'une unite centrale de 
microprocesseur, d'une memoire a lecture 

25 seule (ROM) contenant notamment des routi - 

nes fonctionnelles exclusivement executables 
par I'unite centrale et sous sa dependance, en 
ce.que dans I'espace d'adressage de la me- 
moire programmable sont d£limit£es une zone 

do dite de repertoire et une zone dite des appli - 
cations, lesquelles zones sont exclusives Tune 
de i'autre, en ce que la zone de repertoire 
contient une table repertoire ou les adresses 
de debut et de fin ainsi qu'un code de r£te- 

35 rence de chacun des programmes duplica- 

tions susceptible d'etre charge dans une por- 
tion de la zone des applications, sont inscrits 
au fur et a mesure du chargement desdits 
programmes et en utilisant une desdites rou - 

40 tines fonctionnelles, en ce que le circuit de 
contrdle d'adressage est agence pour inhiber 
les commandes d'ecriture et de lecture de la 
memoire programmable pour des adresses qui 
se srtuent a I'exterieur de I'intervalle defini par 

45 les valeurs limites de debut et de fin d'une 

application designee prealablement sur les 
acefcs d'entree- sortie, limites qui sont m6- 
morisees dans des registres verrouillables, 
appeies registres de limites, tandis que la voie 

so dite d'autorisation prioritaire comporte des 
moyens pour s'affranchir de I'inhibition preci- 
tee en autorisant recriture et la lecture de la 
zone de repertoire a la condition exclusive que 
ces operations soient effectuees au moyen 

55 d'une desdites routines fonctionnelles durant 

une etape operatoire predeterminee durant 
laquelle les registres contenant les valeurs li - 
mites sont deverrouilies. 
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2. Microcircuit selon la revendication 1, characte- 
rise en ce qu'il comporte une bascule bistable, 
plac^e dans un premier etat exclusivement lors 
d'une mise sous tension du microcircuit, puis 
plac£e dans un deuxi&me etat oppose au s 
premier d§s qu'un compteur ordinal associe h 
I'unite centrale, contient une valeur d'adresse 
comprise dans I'espace d'adressage de la 
m£moire programmable, et en ce que cette 
bascule bistable deiivre un signal de 10 
verrouillage/d§verrouillage pour la commando 

de verrouiliage des registres de limites et pour 
la commande de la voie d'autorisation priori - 
taire. 

75 

3. Microcircuit selon la revendication 2, caracte - 
rise en ce que ladrte bascule bistable peut 
egalement etre plac^e dans ledit deuxfeme 
etat par un signal de commande deiivre par 
I'unite centrale sous I'effet d'une routine tone- 20 
tionnelle pr£vue & cet effet. 

4. Microcircuit selon rune des revendications 1 & 
3, caracterise en ce que le circuit de controls 
d'adressage comporte une porte OU dite de 25 
validation, dont la sortie commande la tran- 
smission des signaux d'ecriture et de lecture 

de la m^moire programmable, en ce qu'une 
premiere entree de cette porte de validation 
regoit un signal resultant de la comparaison de 30 
toute adresse appel£e avec le contenu des 
registres de limites, et une autre entree par 
laquelle s'effectue I'autorisation prioritaire, re - 
goit un signal resultant du produit logique entre 
le signal de verroui 1 1 age/de verrouiliage et le 35 
signal de sortie d'un d^codeur d'adresses re - 
connaissant les seules adresses de la zone de 
repertoire. 



lecture, d'ecriture et d'effacement, h la sortie 
d'une porte OU additionnelle. 



5. Microcircuit selon la revendication 4, caracte - aq 
ris6 en ce qu'une zone dite "publique" est en 
outre prgvue dans I'espace d'adressage de la 
m£moire programmable, zone qui est distincte 

de la zone de repertoire et de la zone des 
application, et en ce que le circuit de controls 45 
d'adressage comporte un d£codeur d'adresse 
supplemental reconnaissant les seules 
adresses de la zone publique, qui deiivre en 
sortie un signal applique* & une entree sup- 
plemental de la porte OU de validation. so 

6. Microcircuit selon Tune des revendications 4 
ou 5, caracterise en ce qu'un signal de de- 
tection d'anomalie (INT) est produit en sortie 
d'une porte ET additionnelle dont une pre- 55 
miere entree regoit le signal issu de la porte 

de validation, et une deuxieme entree regoit la 
somme logique des signaux de commande de 
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